寥寥数行SVG实现圆环loading或倒计时效果 « 张鑫旭 您所在的位置:网站首页 浏览器IMG图片原生懒加载loading=lazy实践指南 « 张鑫旭 寥寥数行SVG实现圆环loading或倒计时效果 « 张鑫旭

寥寥数行SVG实现圆环loading或倒计时效果 « 张鑫旭

2024-05-18 15:23| 来源: 网络整理| 查看: 265

by zhangxinxu from http://www.zhangxinxu.com 本文地址:http://www.zhangxinxu.com/wordpress/?p=4889

一、无题

如题。

于2017年11月2日新增案例

实际项目开发时候,设计师设计的还原可能不是下面这种纯色的圆环,而是一种复合渐变效果,类似下图:

彩条圆环

也是可以实现的,原理是使用两个渐变半圆无缝叠加在一起就可以了。

完整案例(含10秒倒计时JS代码),可狠狠地点击这里体验:SVG与多彩渐变圆环倒计时效果demo

其中SVG中使用了3个,如下截图: 3个圆环元素

分别表示底部灰色完整圆环,左半渐变圆环和右半渐变圆环。

二、历史正文

设计师设计了一个图片上传圆环loading进度效果。如下截图: loading效果截图

首先,CSS3是可以实现的,以前写过一篇转大饼的文章:“CSS3实现鸡蛋饼饼状图loading等待转转转”。原理跟这个一模一样,两个半区的矩形,然后不同时机巧妙显隐实现。

但是呢,CSS3实现不太好理解,进度控制也不容易,最好直接数值变一变,进度效果就出来。

有没有其他方法呢?

哈,当然有,可以使用同样IE9+支持的SVG.

我们只需要一个实线背景圆,一个虚线变化圆两个圆就可以了。

百闻不如一见,您可以狠狠地点击这里:SVG实现圆环loading进度效果demo

拖动demo下面的range区域选择控件(0-100%)就会发现蓝色高亮圆环跟着一起变化了: 圆环效果截图

SVG代码非常简单,如下示意:

其中,上面红色加粗的就是效果实现的关键。

stroke-dasharray在SVG中表示描边是虚线,两个值,第一个是虚线的宽度,第二个是虚线之间的间距。下面就是一些虚线数据值以及最后的效果表现(实时,非截图,IE9+浏览):

之前写了篇“纯CSS实现帅气的SVG路径描边动画效果”,就是stroke-dasharray的妙用。

这里也是类似原理。

理解了stroke-dasharray,我们的事情就简单了,我们只需要让间距永远不小于圆的周长,然后,虚线的长度 = 百分比值 * 圆的周长就可以了。

简单,超乎想象:

// 假设周长是1068, percent是百分比值 circle.setAttribute('stroke-dasharray', 1068 * percent + " 1069");

就OK了。

哦~~差点忘了。默认stroke-dasharray的起始位置在右侧,而不是上方,因此,偶们需要使用transform逆时针旋转90°, 这就是第二个circle元素上面transform="matrix(0,-1,1,0,0,440)"的由来。

更新于2016年11月24日 测试发现,iOS 手机上,貌似transform逆时针旋转90°只会改变图形外观,但是其坐标起始位置还是右侧。因此,更改起始坐标可能还需要通过外部容器旋转控制。

更新于2017年11月1日 感谢辉辉的反馈,iOS手机上起始坐标异常问题,可以通过添加如下CSS修正:

svg { -webkit-transform: rotate(-0.05deg); transform: rotate(-0.05deg); } 三、结语

目前越来越多移动端图标展示需求,很多开源图表框架的问题在于,体积大,UI很难改变,无法满足设计需求。且一般移动端的展示都比较简单,此时,使用简单的SVG实现是性价比最高的方式。

所以,好好学学SVG,比追逐热点更受益。

本文为原创文章,会经常更新知识点以及修正一些错误,因此转载请保留原出处,方便溯源,避免陈旧错误知识的误导,同时有更好的阅读体验。 本文地址:http://www.zhangxinxu.com/wordpress/?p=4889

(本篇完)

相关文章纯CSS实现帅气的SVG路径描边动画效果 (0.510)CSS var变量的局部作用域(继承)特性 (0.327)更好的纯CSS滚动指示器技术实现 (0.327)妙法攻略:渐变虚框及边框滚动动画的纯CSS实现 (0.163)浏览器IMG图片原生懒加载loading="lazy"实践指南 (0.163)使用navigator.connection.downlink前端测网速 (0.163)我使用CSS模拟个假的数字loading效果 (0.163)聊聊Web网页中资源加载的优先级 (0.163)使用SVG实现gradient背景渐变 (0.020)了解:使用CSS namespace进行分隔 (0.020)理解SVG viewport,viewBox,preserveAspectRatio缩放 (RANDOM - 0.020)


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有